

# Universidad Carlos III Computer Structure Microprogramming introduction Course 2019-20

Members:

Álvaro Marco Pérez / 100383382

Ramón Hernández León / 100383351

GROUP: 88

## Index

| Exercise 1: Design of the instructions | 2 |
|----------------------------------------|---|
| Exercise 2: instruction testing        | 5 |
| Advantages and disadvantages of Z80    | 6 |
| Conclusions                            | 7 |
| Problems encountered                   | 7 |

## Exercise 1: Design of the instructions

| Instruction name | С  | Elementary<br>operations         | Control signals                                                                                                | Design decisions                                                                                                                                                                                      |
|------------------|----|----------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Id               | C1 | BR[R_target] ← BR[R_source]      | SELC=10101,<br>SELA=10000, MR=0, LC=1,<br>T9=1                                                                 | As we are not using the internal bus, we can operate the instruction completely in only one cycle.                                                                                                    |
| ldi              | C1 | BR[R_target] ← U16               | SELC=10101, MR=0, SE=0,<br>SIZE=10000,<br>OFFSET=00000, T3, C, LC                                              | As we only use the internal bus for taking U16 from IR, we can operate the instruction in only one cycle.                                                                                             |
| ld               | C1 | MAR← BR[R_source]                | SELA=10000, MR=0, T9=1,<br>C0=1                                                                                | In the codification of<br>this instruction we<br>have used three<br>cycles as we had to<br>use two times the<br>internal bus and we<br>had to wait MAR's<br>signal to be written<br>before reading it |
|                  | C2 | MBR ← M[MAR]                     | TA=1, R=1, BW=11, M1=1,<br>C1=1                                                                                |                                                                                                                                                                                                       |
|                  | C3 | $BR[R\_target] \leftarrow MBR$   | SELC=10101, MR=0, T1=1,<br>LC=1                                                                                |                                                                                                                                                                                                       |
| add_a            | C1 | $A \leftarrow A + BR[R\_source]$ | SelA=10101, MR=0, T9, C4                                                                                       | Two cycles were needed in this instruction because we had to take the source register with MR=0 (from IR) and A register with MR=1, which obliges us to divide the operation                          |
|                  | C2 | A ← A + R_source                 | SELB=00100, MR=1,<br>MA=1, MB=00,<br>SELCOP=01010, MC=1,<br>SELP=11, M7=1, C7=1, T6,<br>SELC=00100, MR=1, LC=1 |                                                                                                                                                                                                       |
| addi_a           | C1 | RT2 ← S16                        | SE=1, SIZE=10000,<br>OFFSET=00000, T3, C5                                                                      | We have to wait to S16 to be stored in RT2, this makes a cycle. Then we store the value of the addition in A.                                                                                         |
|                  | C2 | $A \leftarrow RT2 + A$           | SELA=00100, MR=1,<br>MA=0, MB=01,<br>SELCOP=01010, MC=1,<br>SELP=11, M7, C7, T6,<br>SelC=00100, MR=1, LC=1     |                                                                                                                                                                                                       |
| inc              | C1 | R_source ← BR[R_source] +1       | SelA=10101, MR=0, MA=0,<br>MB=11, SELCOP=01010,<br>MC=1, T6, SelP=11, M7=1,                                    | We have been able<br>to take the source<br>register from IR, add                                                                                                                                      |

|      |    |                                                    | C7, SelC=10101, MR=0, LC                                                                                  | one to its content, and store this value in it.                                                                                                                                                                                                                                      |
|------|----|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dec  | C1 | R_source ← BR[R_source] -1                         | SelA=10101, MR=0, MA=0,<br>MB=11, SELCOP=01011,<br>MC=1, T6, SelP=11, M7=1,<br>C7, SelC=10101, MR=0, LC   | We have been able to take the source register from IR, subtract one to its content, and store this value in it.                                                                                                                                                                      |
| qį   | C1 | RT2 ← S16                                          | SE=1, Size=10000,<br>Offset=00000, T3, C5                                                                 | For the first and second cycle we stored S16 and PC respectively, as both need to use the internal bus. Then we perform the addition.                                                                                                                                                |
|      | C2 | RT1← PC                                            | T2, C4                                                                                                    |                                                                                                                                                                                                                                                                                      |
|      | СЗ | PC ← RT1+ RT2                                      | MA=1, MB=01,<br>SELCOP=01010, MC=1, T6,<br>M2=0, C2                                                       |                                                                                                                                                                                                                                                                                      |
| jpz  | C1 | RT2 ← PC                                           | T2, C5                                                                                                    | We have make the                                                                                                                                                                                                                                                                     |
|      | C2 | RT1 ← S16<br>if (previous SR ==0)<br>→ go to fetch | SE=1, Offset=00000,<br>Size=10000, T3, C4,<br>MADDR=fetch, B=0, A0=0,<br>C=110                            | instruction as fast as possible. The first two cycle were needed to add PC and S16. The separation between cycles 3 and 4 was also needed because we had to use twice the ALU. On the 5th cycle we needed to check if S16 was equal to 0 and then, if not, writing this value on PC. |
|      | СЗ | $RT3 \leftarrow RT1 + RT2$                         | MA=1, MB=01,<br>SelCop=1010, MC=1, C6                                                                     |                                                                                                                                                                                                                                                                                      |
|      | C4 | $RT1 \leftarrow SR$ $SR \leftarrow S16*1$          | MA=1, MB=11,<br>SelCop=1100, MC=1,<br>SelP=11, M7=1, C7, T8, C4                                           |                                                                                                                                                                                                                                                                                      |
|      | C5 | If $(S16==0) \rightarrow go to$ fetch              | MADDR=fetch, B=0, A0=0, C=110                                                                             |                                                                                                                                                                                                                                                                                      |
|      | C6 | PC ← RT3<br>SR ← RT1 * 1                           | T7, M2=0, C2, MA=1,<br>MB=11, SelCop=1100,<br>MC=1, SelP=11, M7=1, C7                                     |                                                                                                                                                                                                                                                                                      |
| call | C1 | $MAR \leftarrow SP - 4$ $SP \leftarrow SP - 4$     | SelA=11101 MR=1, MA=0,<br>MB=10, SelCop=1011,<br>MC=1, T6, C0, SelC=11101,<br>LC                          | In this instruction we have used the less possible number of cycles. In each one of them we use the internal bus for different purposes.                                                                                                                                             |
|      | C2 | MBR ← PC                                           | T2, M1=0, C1                                                                                              |                                                                                                                                                                                                                                                                                      |
|      | C3 | Mem[MAR] ← MBR<br>PC ← U16                         | Ta, BW=11, Td, W, SE=0,<br>Size=10000, Offset=0, T3,<br>M2=0,C2, SE=0,<br>Size=10000, Offset=00000,<br>T3 |                                                                                                                                                                                                                                                                                      |

| Ret  | C1 | $MAR \leftarrow SP$ $RT3 \leftarrow SP + 4$    | SelA=11101, MR=1, T9, C0,<br>MA=0, MB=10,<br>SelCop=1010, MC=1, C6                      | In the second cycle we have take advantage that we had to access memory to pass the value in RT3 to the SP register.                                                                                |
|------|----|------------------------------------------------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | C2 | $SP \leftarrow RT3$ $MBR \leftarrow M[MAR]$    | Ta, R, BW=11, M1=1, C1,<br>T7, SelC=11101, MR=1, LC                                     |                                                                                                                                                                                                     |
|      | C3 | PC ← MBR                                       | T1, M2=0, C2                                                                            |                                                                                                                                                                                                     |
| Halt | C1 | PC ← RA + RB                                   | MA=0, MB=00,<br>SelCop=1010, MC=1, T6,<br>M2=0, C2                                      | As RA and RB are set by default = 0 which each cycle (unless they are used), we use them to add and write the result in PC.                                                                         |
| push | C1 | $SP \leftarrow SP - 4$ $MAR \leftarrow SP - 4$ | SelA=11101, MR=1, MA=0,<br>MB=10, SelCop=1011,<br>MC=1, T6, SelC=11101,<br>MR=1, LC, C0 | The reasons to have three cycles on push instruction were that on cycles one and two we use the internal bus for different reasons, and, in the last cycle, we needed to wait to MBR to be written. |
|      | C2 | MBR ← R_source                                 | SelA=10101, MB=0, T9,<br>M1=0, C1                                                       |                                                                                                                                                                                                     |
|      | СЗ | M[MAR] ← MBR                                   | Ta, BW=11, Td, W                                                                        |                                                                                                                                                                                                     |
| рор  | C1 | $MAR \leftarrow SP$ $RT3 \leftarrow SP + 4$    | SelA=11101, MR=1, T9, C0,<br>MA=0, MB=10,<br>SelCop=1010, MC, C6                        | We use three cycles in this instruction as in each one of them the internal bus is used for different purposes.                                                                                     |
|      | C2 | $MBR \leftarrow M[MAR]$ $SP \leftarrow RT3$    | Ta, R, BW=11, M1=1, C1,<br>MR=1,SelC=11101, MR=1,<br>T7, LC                             |                                                                                                                                                                                                     |
|      | C3 | SP ← MBR                                       | SelC=10101, MR=0, T1, LC                                                                |                                                                                                                                                                                                     |

At the end of each instruction we jump to fetch, with the following microcode instructions:

C=0, B=1, A0=1

### Exercise 2: instruction testing

```
.data
   vector: .word 1, 2, 3, 4, 5, 6, 7, 8, 9, 10
.text
   addv:
     ##push $a0 and $a1
       #----addi $sp $sp -8
         ld A SP
         addi_a -8
         ld SP A
         #----sw $a0 0($sp)
         ld IX (SP)
       #----sw $a1 4($sp)
         ld A SP
         addi_a 4
         ld SP A
         ld IY (SP)
      ##$v0 will contain the addition of the vector elements
         #----li $v0 0
         ldi HL 0
       #----beq $a0 $0 f1
         ld A IX
         addi_a 0
         jpz 0x0805c
         #----lw $t0 ($a1)
         ld BC (IY)
         #----add $v0 $v0 $t0
         ld A HL
         add_a BC
         ld HL A
         #----addi $a1 $a1 4
         ld A IY
         addi a 4
         ld IY A
         #----addi $a0 $a0 -1
         ld A IX
```

```
addi a −1
   ld IX A
  #----b b1
   call 0x08024
##pop $a1 and $a0
 #----lw $a0 0($sp)
   ld IX (SP)
  #----lw $a1 4($sp)
   ld A SP
   addi a 4
  ld IX (A)
  #----addi $sp $sp 8
   ld A SP
   addi_a 8
   ld SP A
##return
  #----jr $ra
  Ret
main:
  ##call addv subroutine
    #----li $a0 10
     ldi IX 10
    #----la $a1 vector
     ldi IY 0x01000
    #----jal addv
    call 0x08000
  # Finish the program
    #----li $v0 10
     ldi HL 10
    #----syscall
     Halt
```

#### Advantages and disadvantages of Z80

On one hand, Z80 has few instructions and registers available. This makes instructions that were direct in MIPS32, much complex on Z80.

On the other hand, for this reason Z80 is easier to debug and update, which makes the program more dynamic.

#### Conclusions

Microprogrammed control units are much flexible and powerful than wired ones since they can be adapted to any other architecture. In addition, if the instructions are microprogrammed optimally, the performance of the control unit is also very high.

Apart from this design conclusion, we have learned to code a microprogrammed a control unit.

Taking all together we have taken a good insight into the physical execution of the instructions inside the processor. In the end just performs simple arithmetic operations with binary values while the control unit takes all important decisions.

#### Problems encountered

When we were encoding and testing, separately, each instruction all of them were executed correctly. Nevertheless, when more than one came together some strange behaviour was observed (and afterwards corrected). Specially during the execution of the test program we noticed that many of MIPS32 instructions do not have an equivalent instruction in Z80. For that reason the same test program written with Z80 instructions is longer than the MIPS32 version.

From the beginning of this assignment, the interactive tools available in WepSim have made the testing of the instructions much easier. The values of all the components can be seen and modified. Learning how to use this tools has been crucial for reaching the goal of the practice.